package top.ysh.producer;

import com.rabbitmq.client.BuiltinExchangeType;
import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;
import com.rabbitmq.client.ConnectionFactory;

import java.io.IOException;
import java.util.concurrent.TimeoutException;

/**
 * Routing模式
 */
public class Producer_Routing {
    public static void main(String[] args) throws IOException, TimeoutException {

        // 1. 创建连接工厂
        ConnectionFactory factory = new ConnectionFactory();
        // 2. 设置参数
        factory.setHost("192.168.23.131");  // docker容器宿主机ip，不设置参数默认localhost
        factory.setPort(5672);    // 端口，默认：5672
        factory.setVirtualHost("/");    // 虚拟机，默认值： /
        factory.setUsername("guest");    // 用户名，默认值：guest
        factory.setPassword("guest");    // 密码，默认值：guest
        // 3. 创建连接 Connection
        Connection connection = factory.newConnection();
        // 4. 创建 Channel
        Channel channel = connection.createChannel();
        // 5. 创建交换机
        /*
            exchangeDeclare(String exchange,
                BuiltinExchangeType type,
                boolean durable,
                boolean autoDelete,
                boolean internal,
                Map<String, Object> arguments
            )throws IOException
            参数：
                1. exchange：交换机名称
                2. type：交换机类型
                    DIRECT("direct")：定向
                    FANOUT("fanout")：扇形（广播），发送消息到每一个与之绑定队列
                    TOPIC("topic")：通配符方式
                    HEADERS("headers")：参数匹配
                3. durable：是否持久化
                4. autoDelete：自动删除
                5. internal：内部使用，一般false
                6. arguments：参数
         */
        String exchangeName = "test_direct";
        channel.exchangeDeclare(exchangeName, BuiltinExchangeType.DIRECT, true, false, false, null);
        // 6. 创建队列Queue
        String queue1Name = "test_direct_queue1";
        String queue2Name = "test_direct_queue2";
        // 声明
        channel.queueDeclare(queue1Name, true, false, false, null);
        channel.queueDeclare(queue2Name, true, false, false, null);
        // 7. 绑定队列和交换机
        /*
         Queue.BindOk queueBind(String queue, String exchange, String routingKey) throws IOException
         参数：
            1. queue：队列名称
            2. exchange：交换机名称
            3. rautingKey：路由键，绑定规则
                如果交换机类型为fanout，routingKey设置为""
         */
        // 队列1绑定：error
        channel.queueBind(queue1Name, exchangeName, "error");
        // 队列2绑定：info error warning
        channel.queueBind(queue2Name, exchangeName, "info");
        channel.queueBind(queue2Name, exchangeName, "error");
        channel.queueBind(queue2Name, exchangeName, "warning");

        String body = "日志信息：张三调用了findAll方法...日志级别：info...";
        // 8. 发送消息
        channel.basicPublish(exchangeName, "info", null, body.getBytes());
        // 9. 释放资源
        channel.close();
        connection.close();
    }
}
